package com.fbb.service.impl;

import com.fbb.pojo.Book;
import com.fbb.mapper.BookMapper;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 书(Book)表服务实现类
 *
 * @author fbb
 * @since 2022-03-02 20:14:38
 * @version 1.0
 */
 
@Service("bookService")
public class BookServiceImpl {
    @Resource
    private BookMapper bookMapper;

    /**
     * 根据模糊条件查询总个数
     *
     * @param name 查询条件
     * @return 返回查询到的总个数
     */
    public Map<String, Object> selectForCount(String name) {
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 200);
        map.put("msg", "查询成功");
        map.put("data", this.bookMapper.selectForCount(name));
        return map;
    }

    /**
     * 查询所有数据
     
     * @return  返回所有数据
     */
    public List<Book>  selectAll() {
        //注意：mapper的查询语句一定要紧跟其后
        PageHelper.startPage(1,2);
        List<Book> books = bookMapper.selectAll();
        PageInfo<Book> info = new PageInfo<>(books);
        List<Book> list = info.getList();
        System.out.println("总条数"+info.getTotal());
        System.out.println("当前页"+info.getPageNum());
        System.out.println("每页条数"+info.getPageSize());
        System.out.println("总页数"+info.getPages());
        return list;
    }

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    public Map<String, Object> selectById(Integer id) {
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 200);
        map.put("msg", "查询成功");
        map.put("data", this.bookMapper.selectById(id));
        return map;
    }

    /**
     * 查询分页数据
     *
     * @param index 查询起始位置
     * @param name  查询条件
     * @param limit 分页数量
     * @return 对象列表
     */
    public Map<String, Object> selectForPage(int index, int limit, String name) {
    // 获取当前表中的总记录
        int tableCount = this.bookMapper.selectForCount(name);
        // 总页码计算   (总条数 - 1) / 每页显示条数  + 1
        // (100 - 1) / 10 + 1 = 10        (101 - 1) / 10 + 1 = 11      (99 - 1) / 10 + 1 = 10
        int pageCount = (tableCount - 1) / limit + 1;
        // 计算每页开始的下标值
        index = (index - 1) * limit;
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 0);   
        map.put("msg", "查询成功");
        // 查询的记录总页码
        map.put("pageCount", pageCount);  
        // 当前表中的总条数
        map.put("count", tableCount);    
        map.put("data", this.bookMapper.selectForPage(index,limit,name));
        return map;
    }

    /**
     * 新增数据
     *
     * @param book 实例对象
     * @return 实例对象
     */
    public Map<String, Object> insert(Book book) {
        // UUID.randomUUID()  返回内容：asd21321-ewrewrew213213-123213zsad-123asdasd这样的形态
        this.bookMapper.insert(book);
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 200);   
        map.put("msg", "新增成功");
        return map;
    }

    /**
     * 通过ID查询单条数据
     *
     * @param book 实例对象
     * @return 实例对象
     */
    public Map<String, Object> updateById(Book book) {
        this.bookMapper.updateById(book);
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 200);   
        map.put("msg", "更新成功");
        return map;
    }

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    public Map<String, Object> deleteById(String id) {
        this.bookMapper.deleteById(id);
        Map<String, Object> map = new HashMap<>();
        // 前端端分离时，前端人员会首先判断code值是否满足200，如果不是200，则提醒用户失败
        map.put("code", 200);   
        map.put("msg", "删除成功");
        return map;
    }
}
